Scroll to navigation

OPENAT(2) Руководство программиста Linux OPENAT(2)

ИМЯ

openat - открывает файл, определяемый относительно файлового дескриптора каталога

ОБЗОР

#include <fcntl.h>

int openat(int dirfd, const char *pathname, int flags);
int openat(int dirfd, const char *pathname, int flags, mode_t mode);


Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

openat():

Начиная с glibc 2.10:
_XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
До glibc 2.10:
_ATFILE_SOURCE

ОПИСАНИЕ

Системный вызов openat() работает также как системный вызов open(2), за исключением случаев, описанных в данной справочной странице.

Если в pathname задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор dirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в open(2)).

Если в pathname задан относительный путь и dirfd равно специальному значению AT_FDCWD, то pathname рассматривается относительно текущего рабочего каталога вызывающего процесса (как open(2)).

Если в pathname задан абсолютный путь, то dirfd игнорируется.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении openat() возвращает новый файловый дескриптор. При ошибке возвращается -1, и errno устанавливается в соответствующее значение.

ОШИБКИ

В openat() могут возникнуть те же ошибки, что и в open(2). Также, в openat() могут возникнуть следующие ошибки:

dirfd не является правильным файловым дескриптором.
Значение pathname содержит относительный путь и dirfd содержит файловый дескриптор, указывающий на файл, а не на каталог.

ВЕРСИИ

Вызов openat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2008. Подобный системный вызов есть в Solaris.

ЗАМЕЧАНИЯ

Вызов openat() и другие подобные системные вызовы с суффиксом «at» поддерживаются по двум причинам.

Во-первых, openat() позволяет приложению избежать условий состязательности, которые могут возникнуть, когда open(2) открывает файлы в каталогах, отличных от текущего. Состязательность возникает из-за того, что один из компонентов префикса каталога, указанного open(2), может измениться одновременно с вызовом open(2). Этой состязательности можно избежать открыв файловый дескриптор каталога назначения, и затем указав этот файловый дескриптор в аргументе dirfd вызова openat().

Во-вторых, openat() позволяет реализовать отдельный «текущий рабочий каталог» для каждой нити посредством файлового дескриптора, сопровождаемого приложением. Эта возможность также может быть получена с использованием /proc/self/fd/dirfd, но менее эффективно.)

СМОТРИТЕ ТАКЖЕ

faccessat(2), fchmodat(2), fchownat(2), fstatat(2), futimesat(2), linkat(2), mkdirat(2), mknodat(2), open(2), readlinkat(2), renameat(2), symlinkat(2), unlinkat(2), utimensat(2), mkfifoat(3), path_resolution(7)

2012-05-04 Linux